WORLD INTELLECTUAL PROPERTY ORGANIZATION 
International Bureau 




per 

INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT) 



(51) International Patent Classification 5 
G06F 15/00 



Al 



(11) International Publication Number: WO 93/25968 

(43) International Publication Date: 23 December 1993 (23.12.93) 



(21) International Application Number: PCT/US93/05557 

(22) International Filing Date: 10 June 1993 (10.06.93) 



(30) Priority data: 
896,243 



10 June 1992(10.06.92) 



US 



(71X72) Applicant and Inventor: FURTEK, Frederick, C. [US/ 
USI; 350 Sharon Park Drive, Menlo Park, CA 94025 
(US). 

(74) Agents: MORRIS, Francis, E. et al.; Pennie & Edmonds, 
1155 Avenue of the Americas, New York, NY 10036 
(US). 



(81) Designated States: JP, KR, European patent (AT, BE, CH, 
DE, DK, ES, FR, GB, GR, IE, IT, LU, MC, NL, PT, 
SE). 



Published 

With international search report. 

Before the expiration of the time limit for amending the 
claims and to be republished in the event of the receipt of 
amendments. 



^) Title: A MODULAR COMPUTER BASED ON RECONFIGURABLE LOGIC 



.22o 22b, 22c 




23 




H H f3 (3 0 0 
SIMM CONNECTORS (SRAM) 

a a a a a a 



i 1 



SIMM CONNECTORS 
(DRAM) 



23o 23b 23c 



(57) Abstract 



A modular computer includes a backplane (20) on which various modules can be interchangeably installed, thereby provid- 
; g interconnections between the modules. Modules are selected to meet application requirements, and may include, for example, 
reconfigurable-logic modules (51a-5lc) and processor modules (40). The backplane provides connections to extend an effective 
array (21) of reconfigurable-logic cells across multiple reconfigurable-logic modules without substantial performance limitations. 
Other connections in the backplane facilitate flexible, high speed I/O (22), while still others distribute programming signals to 
the various reconfigurable-logic devices in the modular computer (23). The computer can be configured to run both ordinary mic- 
roproocssor software and highly parallel custom software. . , 
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A MODULAR COMPUTER BASED ON RE CONFI GURABLE LOGIC 

FIELD OF THE INVENTION : 

The present invention relates generally to the 
5 field of computer hardware design. In particular, it 
relates to a modular computer system which can be 
flexibly arranged into numerous configurations so as 
to provide both high performance and adaptability to 
multiple application requirements. 

10 

BACKGROUND OF THE INVENTION : 

Conventional computer hardware is typically 
organized into a modular structure which includes a 
backplane (or motherboard) and various boards (or 
15 daughterboards) . In such organizations, the backplane 
serves as a base unit and contains numerous connectors 
to which^ boards can be affixed. The boards contain 
various logical components of the computer hardware, 
such as microprocessors, memory, I/O circuits, 
2 0 reconf igurable-logic devices, etc. Each board 

contains an identical set of pins on an edge connector 
which mounts in one of the backplane connectors. 
Installing a particular board at a given connector 
allows the board's pins to electrically contact the 
25 backplane through the connector. 

The conventional backplane, in addition to 
providing connectors for affixing boards, includes a 
bus which electrically connects the pins of boards 
installed at the various connectors. The bus can be 
30 viewed as a collection of parallel wires, each of 
which connects a particular pin from each of the 
backplane connectors; a single bus connects all the 
boards installed at the different connectors. 
Conventionally, the bus represents the primary means 

35 
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by which electrical connections between hardware 
components on different boards are established. 

While this conventional modular computer 
arrangement allows for great flexibility in terms of 

5 hardware configurations, the use of a single bus to 
interconnect all boards is inherently performance 
limiting. The bus is, in effect, a single 
communication resource shared among the various 
boards. While two boards are using the bus to 

10 communicate, any other set of boards needing to 

communicate must wait until those presently using the 
bus are finished and have "released" the bus. This 
type of performance bottleneck is known as bus 
congestion or contention. Such bus congestion is 

15 frequently a fundamental limitation in the I/O 
bandwidth, memory bandwidth and overall system 
performance of conventional bus-oriented modular 
computer designs. 

For the past several years, field-programmable 

2 0 gate arrays (FPGAs) have been the fastest growing 
segment of the semiconductor market. FPGAs are 
reconf igurable-logic circuits in which the connections 
between various logical components are electrically 
programmable. Typically, an FPGA is organized as a 

25 regular array of identical cells, each of which 

contains one or more combinational or sequential logic 
circuits. In most commercially available FPGAs, the 
individual cells include some type of storage register 
and a number of combinational gates. Besides the 

30 cells, an FPGA also includes programmable connection 
resources between various (primarily neighboring) , 
cells in the array. An FPGA is configured by 
electronically selecting both the configurations of 
individual cells so as to determine the logical 

35 operation performed by each cell and the configuration 
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of the inter-cell connection resources so as to 
determine the logical connections between cells. 
Commercially available FPGAs can be electronically 
configured or reconfigured within milliseconds to 
5 implement a vast range of logical circuits. 

Researchers have recognized that FPGAs can be 
used to achieve dramatic increases in computer 
performance. See, for example, P. Bert in , D. Roncin 
and J. Vuillemin, "Programmable Active Memories: a 
10 Performance Assessment" , First int ernational ACM/SIGDA 
Workshop on Field Programmable Ga te Arrays, February 
14 , 1991 (additional material distributed at 
conference) . A programmable active memory (PAM) is a 
hardware co-processor consisting of several FPGAs and 
15 some local memory organized onto a single board and 
interfaced to a host processor using a standard 
bus-oriented interface. As reported, PAMs have been 
used to achieve dramatic speedup for a variety of 
compute-intensive applications. 
2 0 Other PAM-like add-on board approaches have been 

reported. The article "Building and Using a Highly 
Parallel Programmable Logic Array" by M. Gokhale, W. 
Holmes, A. Kosper, S. Lucas, R. Minnich, D. Sweely and 
D. Lopresti, IEEE Computer , January, 1991, reports a 
25 speedup of 330 over a Cray-2 supercomputer on a 

pattern matching problem using two PAM-like add-on 
boards in a Sun workstation. The article notes, 
nevertheless, that the add-on boards (collectively 
termed "Splash") are I/O-limited and that many 
30 applications could run an order of magnitude faster 
with better I/O. Another add-on board approach is 
reported in the article "The Use of FPGAs in a Novel 
Computing Subsystem" by I. Buchanan and T. Kean, First 
International ACM/SIGDA Workshop on Fi eld Programmable 
35 Gate Arrays , February 14, 1991. 
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Generally speaking, one key to achieving 
extremely high computational throughput using a PAM or 
other similar reconf igurable-logic add-on board lies 
in the ability to perform parallel data operations 
5 along an entire dimension of an array of cells. Once 
data is loaded into the array, processing can proceed 
at very high speed. In fact, the processing speed of 
a PAM-type reconf igurable-logic board, as previously 
noted, may quickly exhaust the I/O bandwidth of the 

10 bus attaching the board to the host processor. 

Moreover, one may wish to install multiple PAM-type 
reconf igurable logic boards so as to expand the 
effective size of the reconf igurable logic array. 
Unfortunately, installing multiple reconf igurable 

15 logic boards on a conventional computer bus does not 
achieve the desired result. The bus, as a shared 
resource, fails to provide adequate bandwidth and 
availability to support the communication between 
sections of an extended reconf igurable logic array. 

2 0 Thus, there remains a present need for a modular 
computer system which provides for modular 
expandability without imposing performance limiting 
I/O restraints on the reconf igurable logic. 



25 SUMMARY OF THE INVENTION : 

Accordingly, one object of the present invention 
is an improved modular computer including both an 
expandable reconf igurable-logic section and a 
conventional microprocessor. 

30 Another object of the invention is an improved 

modular computer including both reconf igurable logic 
and a conventional microprocessor wherein the 
reconf igurable logic can be configured to allow the 
microprocessor to run conventional software. 



35 



Still another object of the present invention is 
an improved modular computer based on reconf igurable 
logic wherein a plurality of reconf igurable-logic 
modules can be installed to provide an expanded 
5 reconf igurable-logic array. 

Still another object of the invention is an 
improved modular computer including reconf igurable 
logic wherein flexible I/O terminals in each 
reconf igurable-logic module allow full speed parallel 
10 I/O into either dimension of an expanded 
reconf igurable-logic array. 

Still another object of the invention is an 
improved modular computer based on reconf igurable 
logic wherein multiple reconf igurable-logic modules 
15 can be installed to form a cylindrically connected 
array. 

Stall another object of the invention is to 
replace a conventional bus with an array of 
configurable-logic elements that provide for multiple 
20 simultaneous communication paths between various 
system elements. 

In accordance with the invention, an improved 
modular computer includes a backplane having a 
plurality of receptacles at which modules may be 
25 installed. At any given time, each receptacle 

accommodates one of a plurality of different modules, 
including a processor module, a reconf igurable-logic 
module or other module. Connections between 
receptacles in the backplane are organized such that 
30 reconf igurable-logic modules installed at adjacent 
receptacles are directly connected so as to form an 
expanded reconf igurable-logic array. The backplane 
further provides for distribution of various control * 
and configuration signals to all installed modules. 
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Any number of reconf igurable-logic modules, 
limited by the number of receptacles, can be installed 
at the receptacles to meet system requirements. Each 
reconf igurable-logic module includes one or more FPGAs 
5 connected such that an effective overall 

two-dimensional array of cells is formed. Connectors 
on each reconf igurable-logic module provide for 1/0 
from cells on the boundary of the two-dimensional 
reconf igurable-logic array. Certain connectors are 

10 used to expand the size of the array in one dimension 
while others are advantageously used to interface with 
a local memory and other generic I/O devices. 

The backplane may also provide receptacles for 
memory modules. Within the modular computer, memory 

15 takes two forms. Static random-access memory (SRAM) 
is used to implement local memories associated with 
the processor, reconf igurable-logic or other boards. 
A dynamic random-access memory (DRAM) associated with 
a processor module allows for execution of 

20 conventional microprocessor software. 

The processor module includes a conventional 
microprocessor advantageously interfaced through one 
or more FPGAs. The FPGA is configured so as to 
emulate the expected interface between the 

25 microprocessor and the DRAM and/or other I/O devices. 
An EPROM memory on the processor board provides for 
power-up configuration of the processor module's FPGA. 

Because cells of the FPGA have both programmable 
connection resources and one or more combinational or 

30 sequential logic circuits, the modular computer of the 
present invention provides both communication and 
computation capabilities in the single structure of 
the expandable array of FPGAs. As a result, the 
present invention eliminates bus congestion while 
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providing the flexibility and expandability of a 
.. modular system. 

BRIEF DESCRIPTION OF THE DRAWINGS : 
5 These and other features and advantages of the 

present invention are illustrated in the following 
drawings, in which: 

Fig. 1 depicts a conventional housing used to 
encase the modular computer; 
10 Fig. 2 depicts a top view of a motherboard and 

its various daughterboard connectors; 

Fig. 3 depicts the external connections for a 
daughterboard ; 

Fig. 4 depicts the components and external 
15 connections for a processor board; and 

Fig. 5 depicts a preferred organization of 
components in a reconf igurable- logic board. 

DETAILED DESCRIPTION OF THE INVENTION : 

2 0 Referring now to Fig. 1, a conventional housing 

10 encases the preferred embodiment of the improved 
modular computer. The front panel 11 of housing 10 
may include an aperture 13 for inserting and removable 
magnetic or other disk cartridges. Similarly, the 

25 back panel 12 may include a plurality of back panel 
connectors (not shown) which interface with I/O 
devices such as a keyboard, mouse, display monitor, 
disk drive, tape drive, printer, etc. Within housing 
10 are most of the components typically found in a 

30 standard personal computer chassis. These include a 
power supply, motherboard, and mounting brackets for { 
hard and floppy disk drives. 

The previous Summary of the Invention refers to a 
backplane having receptacles to which modules attach. 

35 The text describing the preferred embodiment, below, 
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refers to a motherboard having daughterboard 
connectors to which daughterboards attach. These 
changes in terminology are in no way intended to be 
limiting; rather, the terms "motherboard" and 
5 "daughterboard" have been adopted merely to provide a 
more concrete and easily understandable description of 
the physical components in the preferred embodiment. 

Referring now to Fig. 2, a motherboard 20 mounts 
to the interior bottom wall of housing 10. Viewed 

10 from the top in Fig. 2, motherboard 20 includes a 
plurality of daughterboard connectors 21, generic 
connectors 22, static random access memory (SRAM) 
single inline memory module (SIMM) connectors 23 and a 
plurality of dynamic random access memory (DRAM) SIMM 

15 connectors 24. 

Overall, housing 10 and motherboard 20 are 
designed" to maximize the use of standard parts 
wherever such use does not substantially limit the 
performance of the computer. Accordingly, the 

2 0 preferred embodiment of the improved modular computer 
provides for use of off-the-shelf SIMM memory modules 
which may be installed at connectors 23 and 24. 
Similarly, logic components are mounted onto 
daughterboards which are interchangeably installed at 

25 daughterboard connectors 21. In accordance with the 
invention, however, the structure of the 
daughterboards and the interconnections between 
daughterboards provided by motherboard 20 and 
connectors 21, 22, 23, and 24, are organized in a 

30 novel manner such that extremely high performance can 
be realized using reconf igurable logic. This modular t 
organization also advantageously provides the ability 
to run standard microprocessor software. These 
aspects and advantages of the invention will become 
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apparent from the discussion of the processor board 
and the reconf igurable-logic board in Figs. 3-5 below. 

Still referring to Fig. 2, each of the 
daughterboard connectors 21a-z is a multi-pin 
5 connector. Some of these pins are connected in a bus 
and commonly connected among all the daughterboards 
while others connect only to adjacent daughterboards 
and still others connect to particular generic 
connectors 22 or SRAM SIMM connectors 23. For 
10 example, daughterboard connector 21b has certain pins 
connecting to a bus shared by all other 
daughterboards, other pins connecting only to adjacent 
daughterboard connector 21a, still other pins 
connecting only to adjacent daughterboard connector 
15 21c, still other pins connecting to respective generic 
connector 22b and still other pins connecting to 
respective SRAM SIMM connector 23b. 

Reference is now made to Fig. 3 which depicts the 
electrical connections to and from a daughterboard 3 0 
2 0 via the daughterboard connectors 21. Each 
daughterboard 30 electrically contacts its 
daughterboard connector with the following sets of 
terminals: (1) control terminals 34; (2) left I/O 35L 
and right I/O 35R terminals; (3) front I/O terminals 
25 36; and (4) rear I/O terminals 37. Of course, each 

daughterboard connector 21, SRAM SIMM connector 23 and 
DRAM SIMM connector 24 also includes power and ground 
terminals which are assumed but not depicted in the 
drawings. Control terminals 34 provide for 
30 distribution of clock and reset signals as well as 

signals for configuring the reconf igurable logic. The 
function of particular control signals 34a-h will be 
discussed in connection with the programming of 
reconf igurable-logic board 50 (Fig. 5). The primary 
35 data connection between daughterboards occurs via the 
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left and right I/O terminals 3 5L and 3 5R respectively. 
Motherboard 20 provides for electrical connection 
between the left I/O terminals 35L of a given 
daughterboard 30 and the right I/O terminals 35R of 
5 one of the daughterboards installed at an adjacent « 
daughterboard connector 21 and for electrical 
connection between the right I/O terminals 35R of the 
given daughterboard and the left I/O terminals 35L of 
the daughterboard installed at the other adjacent 
10 daughterboard connector 21. At the ends, the left and 
right I/O signals wrap around, as do the configuration 
signals. 

For example, the daughterboard installed at 
connector 21b has its left I/O terminals 35L connected 

15 to the right I/O terminals 35R of the daughterboard 
installed at connector 21a. Further, the right I/O 
terminals 3 5R of the daughterboard at connector 21b 
connects to the left I/O terminals 35L of the 
daughterboard at connector 21c. The wrapping around 

20 of the left and right I/O terminals occurs between 

daughterboard connectors 21a and 212. Motherboard 20 
connects the left I/O terminals 35L of the 
daughterboard installed at connector 21a to the right 
I/O terminals 3 5R of the daughterboard at connector 

25 21Z. 

The connections provided between adjacent 
daughterboards via the left and right I/O terminals 
35L and 35R can be viewed, in a sense, as an improved 
data bus. In fact, reconf igurable-logic circuits on 

30 the daughterboards may be configured to connect the 

left and right I/O terminals (of each board) so as to t 
form a virtual data bus. Advantageously, however, not 
having to rely on a conventional data bus connecting 
daughterboard connectors 21a-z eliminates bus 

35 contention problems and leads to substantial 
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performance improvement. The reconf igurable logic can 
operate at its full potential, without the choking 
effect of bus contention associated with other add-on 
reconf igurable-logic board approaches. 
5 Motherboard 2 0 connects the front I/O terminals 

36 of each daughterboard 30 to its respective SRAM 
SIMM connector. Thus, associated with each 
daughterboard 30 is an optional local memory installed 
at the SRAM SIMM connector 23. 
10 Mother board 20 also provides connections between 

the rear I/O terminals 37 of a daughterboard 30 and 
the respective generic connector 22. The generic 
connector 22 provides considerable flexibility in 
configuring the improved modular computer for 
15 particular application needs. For example, several of 
the generic connectors 22 may be linked using a ribbon 
cable or other connection means to form a common bus. 
Generic connectors 22 may also be used to connect with 
various back panel 12 connectors which interface to 
2 0 external devices. Further, the generic connectors may 
be used to connect with various components within 
housing 10, such as DRAM 24 or hard/floppy disks (not 

shown) . 

One important application of the I/O access 
25 provided to each daughterboard 30 via generic 

connectors 22 is high speed parallel I/O, such as the 
so-called "disk striping" or redundant arrays of 
inexpensive disks (RAID) techniques. See, for 
example, P. Chen, An Evaluation of Redundant Arrays of 
30 Inexpensive Disks Using an Amdahl 5890," M.S. thesis, 
Computer Science Division, Tech Report UCB/CSD 89/056, 
1989; M.Y. Kim, Synchronized Disk Interleaving , IEEE 
Transactions on Computers C-35:ll, November, 1986; K. 
Salem and H. Garcia-Molina, Disk Striping, IEEE 1986 
35 International Conference on Data Engineering . 1986. 
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These approaches involve partitioning a single file 
into K similarly sized pieces and storing each piece 
on one of K disk drives. The present invention 
permits each disk drive to be independently controlled 

5 through a different generic connector 22 interfaced to 
a reconf igurable-logic board 50. Thus, the modular 
architecture of the invention can easily be configured 
to control arrays of multiple disks and is ideally 
suited to such high-bandwidth parallel I/O 

10 applications. 

Reference is now made to Fig. 4 which depicts the 
processor board 4 0 and the various connections 
therefrom and thereto. Processor board 40 is 
installed at one of the daughterboard connectors 21 

15 and serves two primary functions in the modular 
computer. First, it provides one means of 
supervising, synchronizing and controlling the 
configuration of the various reconf igurable-logic 
devices within the modular computer system. Second, 

20 it provides a means by which the modular computer can 
be configured and adapted to run ordinary software, 
thus providing an important compatibility feature. 

Processor board 40 includes three main 
components: a microprocessor 41, an FPGA 42, and a 

25 non-volatile memory 43. Memory 4 3 may be used to 

configure FPGA 42 at power-up. FPGA 42 implements a 
flexible interface between processor 41 and numerous 
other components within the modular computer. In 
particular, FPGA 42 is configured to interface between 

30 the data 45 and address 46 busses of microprocessor 41 
and the control signals 34 which are distributed to t 
the daughterboard connectors 21 by motherboard 20. 
FPGA 42 optionally provides interfaces from 
microprocessor 41 to such destinations as non-volatile 

35 memory 43, various motherboard pins 47a, various back 
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panel connectors 47b, DRAM 47c, SRAM and other devices 
47d such as hard and floppy disk drives. The method 
by which control signals 34 are disseminated from 
processor board 4 0 to the various destination FPGAs 
5 will be discussed later in connection with the 
reconf igurable-logic boards 50 (Fig. 5). 

Fig. 4 depicts various sources from which 
such configuration information might be derived. For 
example, processor 41 may utilize prestored 
10 configurations in memory 4 3 to generate appropriate 

control signals 34. Alternatively, processor 41 could 
extract configuration information from DRAM 47c, SRAM 
or other secondary storage 47d and similarly generate 
appropriate configuration signals 3 4 for further 
15 distribution. It should also be noted that, if no 

processor board 4 0 is installed in the motherboard 20, 
configuration of various FPGAs can still be 
accomplished via a back panel connector interfaced to 
provide the control signals 34. 
20 Non-volatile memory 43 includes the necessary 

code to configure FPGA 42 to provide the expected 
interface for processor 41, thereby allowing processor 
41 to execute ordinary software. This involves 
configuring FPGA 4 2 such that it reacts appropriately 
25 to bus control signals 44 and provides the necessary 
connections from the address and/or data busses 45 and 
46 to the DRAM 47C and other I/O devices 47D. Use of 
an FPGA to provide a flexible interface between a 
microprocessor and other computer system resources 
30 such as memory and I/O devices is known in the art of 
conventional computer design. However, such use is 
typically aimed at providing plug-in compatibility of 
future microprocessors which may require slight 
changes in the interface, bus protocol, or timing 
35 requirements. The present invention, in contrast, 
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finds processor 41 placed in a radically different 
environment; FPGA 42 advantageously emulates an 
ordinary interface 44-46 to processor 41 , thereby 
endowing processor 41 with the capability to execute 
5 conventional software in the modular computer » 
environment. 

Reference is now made to Fig. 5 which depicts a 
reconf igurable-logic board 50 illustratively comprises 
four FPGAs 51a-d. Each FPGA comprises a square array 
10 of identical cells and provides I/O terminals at its 
front, rear, left and right boundaries. Within 
reconf igurable-logic board 50, certain I/O terminals 
52 of FPGAs 51a-d are linked front-to-rear so as to 
form an expanded array in the front-to-rear dimension, 
X5 as depicted in Fig. 5. 

The array of cells on reconf igurable-logic board 
50 can, if necessary, be further extended in the 
front-to-rear dimension using the rear I/O terminals 
37 and linking through a generic connector 22 to 
2 0 another reconf igurable-logic board 50. 

In the left-to-right dimension, motherboard 20 
provides for left-to-right linking of I/O terminals 
35L and 35R so as to expand the array. Since the 
right and left I/O terminals at either ends of the set 
25 of daughter board connectors 21 are linked, the cells 
of multiple reconf igurable-logic boards 50 installed 
at daughterboard connectors 21 effectively form a 
cylindrical array geometry. Thus, through the various 
provisions for expandability including the left-to- 
30 right I/O connections between daughterboards, the 

generic connectors and the cylindrical closing of the 
array in the left-to-right dimension, a very large 
number of reconf igurable-logic cells can be linked to 
form an effectively contiguous array which does not 
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suffer from the conventional I/O or bus contention 
bottlenecks. 

As depicted in both Figs. 3 and 5, each 
daughterboard connects to four sets of control signals 
5 34. One set of control signals 34 is provided to each 
FPGA 5la-d on reconf igurable-logic board 50. Each of 
the sets of control signals 34 is used to configure an 
FPGA at a particular location, such as 5ld, on all 
reconf igurable-logic boards 50. The preferred 
10 embodiment of reconf igurable-logic board 50 employs 
CLi6000 Series Field-Programmable Gate Arrays, as 
described in the Product Literature, Rev. IB, 
Concurrent Logic, Inc., May 1992, incorporated herein 
by reference. Figs. 3 and 5 depict the individual 
15 control signals 34, four of which 34a-d are bussed and 
common among all daughterboard connectors 21a-z and 
another "four of which 34e-h connect only between 
adjacent daughterboard connectors. Among the commonly 
bussed signals, Clock 34a and Reset 34b control the 
20 clock and reset functions of flip-flops within the 

individual cells of the FPGAs. The REBOOT line 34c is 
used to assert a request for a system-wide restart, 
and CON (low) 34d indicates, when asserted low, that 
the configuration process is in progress. 
25 Actual configuration data is distributed via the 

adjacently connected terminals 34e-h. Configuration 
signals DO 34e and CCLK 34g originate from processor 
board 40 or a back-panel connector and cascade from 
one reconf igurable-logic board 50 to the next in order 
30 to configure all FPGAs 51 as required. The cascading 
of configuration signals occurs via motherboard 20 
which provides connections between the DATAOUT 34 f and 
CLKOUT 34h terminals of a given board and terminals 
34e and 34g of the daughterboard 30 installed at the 
35 left-adjacent daughterboard connector 21. Thus, for 
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each FPGA 51a-d on a reconf igurable-logic board 50, 
each FPGA receives configuration signals 34e and g 
which either contain configuration data for the given 
FPGA or configuration data for some similarly 
5 positioned FPGA on another board 50* Configuration 
data DO is received by each FPGA 51a-d and read in 
using CCLK 34g. Each FPGA appropriately decodes 
header information in its DO signal to determine 
whether or not to pass this information to another 

10 FPGA. Depending on the header, each FPGA 51a-d may 

relay (or cascade) the configuration data to its left- 
adjacent neighbor board via its DATAOUT terminal 34f 
which it clocks using the CLKOUT terminal 34h. Each 
FPGA receiving the cascaded configuration data makes a 

15 similar determination (based on the header) and 
utilizes or relays the signals accordingly. 
Advantageously, headers provide the ability to 
selectively reconfigure only a portion of the FPGAs on 
one or more reconf igurable-logic boards 50 , thus 

20 saving reconfiguration time and minimizing disruption 
to ongoing computations in other portions of the 
FPGAs. 

Generally speaking, the cylindrical closing of 
the connections between adjacent daughterboards (i.e., 

25 daughterboard connectors 21a and 2lz are considered 
adjacent) allows for flexibility in the positions at 
which various boards may be installed- Boards, other 
than reconf igurable-logic boards 50, that do not make 
use of the left and right I/O terminals 35L and R 

30 and/or the configuration terminals 34 may simply route 
these signals through the daughterboard connector 21 
to maintain signal continuity. Each empty 
daughterboard connector 21 may require the 
installation of a dummy board in order to maintain the 

35 same signal continuity. 
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Although the description of the preferred 
embodiment has focused on only two types of boards 
which form the core of a simple but powerful modular 
computer, numerous other modules and/ or alterations in 
5 the design of the modular computer could be included 
to meet specific application requirements. For 
example, daughterboards might contain one or more 
digital signal processors, floating point or other 
mathematical coprocessors, RAM and/or neural network 

10 devices or cells. The previously described modular 
computer can be configured into either an attached 
computing unit, containing largely reconf igurable- 
logic boards and SRAM and communicating via back-panel 
connectors, or a complete computer system, including a 

15 processor board, reconf igurable-logic boards, SRAM, 
DRAM, hard and floppy disks, optional video and/or 
analog boards, etc. Configurations of the modular 
computer can be used to accelerate such applications 
as file servers, database processing, image 

20 processing, multi-media computing, network protocol 
processing, and real-time data acquisition. Such 
applications may require inclusion of additional 
boards 3 0 containing other digital or analog circuits 
not previously described herein. Such additional 

25 boards, to the extent that they adhere to the modular 
organization and interface framework described herein, 
shall be considered within the scope of the present 
invention. 

Additional features and/or flexibility could also 
30 be added to the motherboard. For example, the 

motherboard could be expanded to accommodate multiple 
parallel rows of daughterboards and/ or the modular 
computer might contain multiple motherboards. Some of 
the electrical connections provided by the motherboard 
35 could be made configurable. Alternatively, certain 
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configurable connections, for example those between 
the DRAM and the daughterboards, could be hard-wired 
into the motherboard, thus potentially providing 
higher performance. 
5 Different array topologies for the 

reconf igurable-logic section, such as spiral, 
toroidal, or hypercube, are practically realizable 
using the modular organization described herein. 
Also, the connections between modules need not be 

10 electronic; any technique capable of transmitting 
logical signals, such as optical coupling, will 
suffice to realize the advantages of the invention. 
Finally, it is also possible to eliminate the need for 
a backplane (or motherboard) entirely. This is 

15 accomplished by forming modules which provide the 

necessary connections by abutment (e.g., the modules 
plug together one above another to form a vertical 
stack) . 

Having described a novel modular organization for 
20 computer components and an exemplary configuration, 
including a processor and reconf igurable-logic board, 
based on the organizational framework, numerous 
alternatives, extensions and improvements will be 
apparent to those skilled in the art. Accordingly, 
25 the present invention shall be defined only in 

accordance with the following claims and equivalents 
thereto. 
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WHAT IS CLAIMED IS: 

1. A modular computer comprising: 

a plurality of modules each including 
reconf igurable-logic circuits, first electrical 
5 terminals and second electrical terminals; and 

module connection means including a 
plurality of installation ports for 
interchangeably installing modules thereat, said 
module connection means providing connections 
10 between the electrical terminals of said modules 

whereby if a particular module is installed at a 
particular port and two other modules are 
installed at ports adjacent to said particular 
port then the first terminals of said particular 
15 module connect to the second terminals of one of 

said other modules while the second terminals of 
said particular module connect to the first 
terminals of the other of said two other modules. 

20 2. A modular computer as defined in claim 1 wherein 

said first terminals of said two other modules are not 
electrically connected to each other and said second 
terminals of said two other modules are not 
electrically connected to each other by said module 

25 connection means. 

3. A modular computer as defined in claim 1 wherein 
each module further comprises control signal terminals 
and said module connection means further provides 

30 electrical connections between the control signal 
terminals of modules installed at all installation 
ports . 

4. A modular computer as defined in claim 1 wherein a 
35 plurality of said modules are reconf igurable-logic 
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modules, each reconf igurable-logic module being 
adapted such that the reconf igurable-logic circuits 
therein form a two-dimensional array, said array being 
connectable with the arrays of other reconf igurable- 
5 logic modules installed at adjacent installation ports * 
so as to extend the array in one dimension. 



5. A modular computer as defined in claim 4 wherein 
the connections between the arrays of two adjacently 
10 installed reconf igurable-logic modules are between the 
first terminals of one of the modules and the second 
terminals of the other module. 



6. A modular computer as defined in claim 1 wherein 
15 each module further includes memory terminals for 

connecting said module to a storage means associated 
therewith". 

7. A modular computer as defined in claim 1 wherein 
20 each module further includes generic terminals for 

connecting said module to I/O or memory resources in 
said computer. 

8. A modular computer comprising: 

25 a processor module including a 

microprocessor ; 

a plurality of reconf igurable-logic modules, 
each including reconf igurable-logic cells 
connected to form an array; and, 

30 a module connecting means for connecting 

said processor module and said reconf igurable- 
logic modules such that said reconf igurable-logic 
modules form an extended array of reconf igurable- 
logic cells and said processor module can realize 
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connections between said microprocessor and said 
extended array. 

9. A modular computer as defined in claim 8 further 
5 comprising a dynamic memory connected to said 

processor module. 

10. A modular computer as defined in claim 9 wherein 
said processor module further comprises a 

10 reconf igurable-logic devices, said reconf igurable- 
logic device in the processor module being 
configurable to provide an interface between the 
microprocessor and the dynamic memory module so as to 
allow the microprocessor to run ordinary software. 

15 

11. A modular computer as defined in claim 8, wherein 
said module connection means further comprises a 
plurality of module receptacles whereat processor 
and/or reconf igurable-logic modules can be 

20 interchangeably installed. 
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